我刚开始在一个非常小的Sinatra应用程序中使用Sequel。因为我只有一个数据库表,所以我不需要使用模型。我想更新一条记录(如果它存在)或者插入一条新记录(如果它不存在)。我提出了以下解决方案:rec=$nums.where(:number=>n,:type=>t)if$nums.select(1).where(rec.exists)rec.update(:counter=>:counter+1)else$nums.insert(:number=>n,:counter=>1,:type=>t)end其中$nums是DB[:numbers]数据集。我相信这种方式不是“更新或插入”行为
假设我有一组数字,例如ary=[1,3,6,7,10,9,11,13,7,24]我想在较小数字跟随较大数字的第一个点之间拆分数组。我的输出应该是:[[1,3,6,7,10],[9,11,13,7,24]]我已经尝试了slice_when,结果非常接近:ary.slice_when{|i,j|i>j}.to_a#=>[[1,3,6,7,10],[9,11,13],[7,24]]但它也在13和7之间拆分,所以我必须加入剩余的数组:first,*rest=ary.slice_when{|i,j|i>j}.to_a[first,rest.flatten(1)]#=>[[1,3,6,7,10],